package com.ddf.springdata.jpa.dao;

import com.ddf.springdata.jpa.entity.IdCard;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

/**
 * @author DDf on 2018/9/29
 */
@Repository
public interface IdCardRepository extends JpaRepository<IdCard, Integer> {
    IdCard getByUserId(Integer userId);

    /**
     * 这里有个奇怪的地方，明明username已经被识别了，如果只用User.username去查询，实际使用USER_ID去查询的
     * where
     *         idcard0_.USER_ID=?
     *  显式的使用解决歧义的方式也不行
     *  IdCard getByUser_Username(String username);
     * @param username
     * @return
     */
    IdCard getByUserUsername(String username);

    /**
     * 参考上面{@link #getByUserUsername}的注释，这里多一个User.password竟然两个条件就被识别了？？
     * where
     *         user1_.USER_NAME=?
     *         and user1_.PASSWORD=?
     * @param username
     * @param password
     * @return
     */
    IdCard getByUserUsernameAndUserPassword(String username, String password);

}
